package com.itheima.tilas.service;

import com.itheima.tilas.Utils.ResultUtil;
import com.itheima.tilas.dto.SelectClazzPageDTO;
import com.itheima.tilas.entity.Clazz;
import com.itheima.tilas.po.InsertClazzOneParam;
import com.itheima.tilas.po.SelectClazzPageParam;
import com.itheima.tilas.po.UpdateClazzParam;
import org.apache.ibatis.annotations.Param;


import java.util.List;

/**
 * 班级服务接口
 */
public interface ClazzService {
    /**
     * 分页查询所有班级信息
     * @param param 存储查询班级条件的变量
     * @return 返回班级信息列表
     */
    ResultUtil selectClazzPage(SelectClazzPageParam param);


    /**
     * 根据id删除班级
     * @param id 存储id的变量
     * @return 返回影响数据的条数
     */
    int deleteClazzById(Integer id);

    /**
     * 插入一条班级信息
     * @param param 存储班级信息的变量
     * @return 返回影响数据库的条数
     */
    int insertClazzOne(InsertClazzOneParam param);

    /**
     * 根据id查询班级信息
     * @param id 要查询的班级id
     * @return 返回班级信息
     */
    SelectClazzPageDTO selectClazzById(Integer id);

    /**
     * 根据id修改班级信息
     * @param param 存储班级信息的变量
     * @return 返回影响数据的条数
     */
    int updateClazzById(@Param("p") UpdateClazzParam param);

    /**
     * 查询所有班级信息
     *
     * @return 返回班级信息列表
     */
    List<Clazz> selectClazzAll();


}
